home *** CD-ROM | disk | FTP | other *** search
/ The Utilities Experience / The Utilities Experience - Volume 1.iso / software / emulation / amstrad / a-cpc.txt < prev    next >
Text File  |  1980-02-05  |  37KB  |  1,189 lines

  1. A-CPC
  2. =====
  3.  
  4. A-CPC is an Amstrad Colour Personal Computer emulator for any Amiga
  5. with Kickstart 2.0 or better.
  6.  
  7. The Amstrad CPC was designed by Amstrad plc. There were 5 models. The
  8. first 3 models appeared from 1984 and were called "CPC". The last 2
  9. models appeared in 1989 and were called the "Plus" range because they
  10. had enhanced hardware to display hardware sprites and a larger colour
  11. palette.
  12.  
  13. The CPC464 had a cassette recorder on the right of the keyboard, and
  14. 64k of memory.
  15.  
  16. The CPC664 had a disk drive on the right of the keyboard and 64k of
  17. memory.
  18.  
  19. The CPC6128 had a disk drive on the right of the keyboard and 128k of
  20. memory.
  21.  
  22. The 464+ had a cassette recorder on the right of the keyboard, enhanced
  23. hardware, different design and 64k of memory.
  24.  
  25. The 6128+ had a disk drive on the right of the keyboard, enhanced hardware,
  26. different design and 128k of memory.
  27.  
  28.  
  29. The CPC models share the same hardware:
  30.  
  31.     - Z80A CPU running at 3.3Mhz
  32.  
  33.     - General Instruments Ay-3-8912 sound generator.
  34.         - 3 channels of tone
  35.         - 1 channel noise
  36.         - simple hardware envelopes with fixed waveforms
  37.  
  38.     - Intel    8255 Parallel Peripheral Interface (general interface
  39.       chip) connected to the sound generator, keyboard, cassette
  40.       hardware, and for miscelaneous information
  41.     
  42.     - uPD765-A or INTEL 8272 Floppy Disk Controller
  43.         - support for 2 drives
  44.         - double density recording
  45.         - 3" discs with two sides (the disc must be turned
  46.           over to use the other side)
  47.         - 40 or 80 disks
  48.         - support for double sided disks
  49.  
  50.     - 6845 Cathode Ray Tube Controller 
  51.         - This chip produces the information to create the
  52.           display
  53.         - hardware scrolling, page flipping
  54.     
  55.     - Gate Array
  56.         - Chip designed by Amstrad
  57.         - translates data from CRTC into graphics and adds
  58.           colours
  59.         - 27 colour pallette (3 levels of Red, Green and Blue)
  60.         - 3 modes
  61.             - 160x200x16
  62.             - 320x200x4
  63.             - 640x200x2
  64.  
  65. There are 2 versions of this emulator package. The demo/evaluation version
  66. and a registered version.
  67.  
  68. The demo/evaluation version is freeware but the program code is (c) copyright
  69. Kevin Thacker. It may be freely copied, provided that the archive contents 
  70. remain intact and you must not charge more than a small fee to cover copying
  71. and the price of the disk. It may be uploaded to a ftp site or BBS (as long
  72. as the BBS doesnt claim copyright on uploaded material) or put  into a PD 
  73. library. If you would like to put it onto a magazine coverdisk or cover CD
  74. then contact me first. (Permission is given to Aminet to distribute
  75. this archive on their CD). The code remains copyright to myself
  76. except for the ROM images which are copyright Amstrad plc and Locomotive
  77. Software Ltd.
  78.  
  79. The demo/evaluation version has been restricted. However, you can still
  80. try out software on the net. It supports loading of Snapshots and disk
  81. images and tape files only.
  82.  
  83. The full version is NOT freeware it is (c) copyright Kevin Thacker. It may 
  84. not be put on a magazine coverdisk, ftp site, cd collection, copied, hired, 
  85. distributed without my written permission. The full version can be obtained 
  86. by contacting me, and it costs 10 UK Pounds or equivalent in your money, 
  87. please add enough money to cover postage if you want the registered version 
  88. to be sent via mail, otherwise just pay the 10 UK pounds and I will send you
  89. the archive by e-mail.
  90.  
  91. Please send the money to my Postal address preferably in UK pounds, or
  92. as an international money order. (I may experience problems trying to
  93. convert the money into my own currency if you do not follow this advice,
  94. and as such you may not recieve the emulator).
  95.  
  96. On receipt of the money, I will either send a disk in the post, or
  97. if you prefer I could email the archive to you.
  98.  
  99. The full version has the following features:
  100.     - current version of the emulator archive
  101.     - read and write to disk images (.DSK)
  102.     - read and write snapshots
  103.     - read from CPC disks directly
  104.     - Make_DSK utility to transfer CPC disks to disk image
  105.     - CPC+ emulation
  106.     - Joystick emulation
  107.     - Multiface 2 emulation (Multiface 2 ROM not included in the archive)
  108.     - a collection of utilities to help you use your CPC software
  109.       with the emulator
  110.  
  111. Updates of the emulator will be available as they are written. If you
  112. already own the emulator, and you would like the update, then send the
  113. disk with money to cover return postage to my address, or I can e-mail
  114. the new archive for free.
  115.  
  116. When a update is available, I will post a message to comp.sys.amstrad.8bit.
  117.  
  118. See the history file for details of updates in the emulation.
  119.  
  120. NOTE:
  121.     You use this emulator at your own risk. I cannot be help responsible
  122.     for any damage caused from the use or mis-use of this product. As
  123.     far as I am aware, there are no fatal bugs that will crash your
  124.     system.
  125.  
  126. ----------------------------------------------------------------------------
  127.  
  128. Requirements
  129. ============
  130.  
  131. To use A-CPC you will need the following:
  132.     - asl.library in your libs/ directory 
  133.       (comes with Workbench2.0 and above)
  134.     - Kickstart 2.0/Workbench 2.0 or better
  135.  
  136. A-CPC supports the following minimum specification: 
  137. (This does not mean mean the emulation will be fast)
  138.     - 68000 CPU
  139.     - OCS chipset
  140.     - 1mb RAM
  141.     - single disk drive
  142.     
  143. To have a fast emulation, I suggest that you need the following:
  144.     - 68020 CPU or better (an accelerate machine)
  145.     - 1mb of true FastRam
  146.     - a harddrive
  147.  
  148. If you have a fast machine I would be interested to hear how fast
  149. it runs at.
  150.  
  151.  
  152. Speed comparisons
  153. =================
  154.  
  155. One guy at Glasgow University who has a A1200 with a 68020-28Mhz accelerator
  156. card and fastram says that the emulation goes at about 2 thirds of the
  157. speed of a real cpc. He also reports that the 68020 specific version is
  158. 5% faster than the 68010 version.
  159.  
  160. In these speed comparisons, the following simple BASIC code was used:
  161.  
  162. 10 for i=0 to 200
  163. 20 print "hi!"
  164. 30 next i
  165.  
  166. A500 - 68000 7Mhz - 1mb Chipram (my machine): 4 mins 09 seconds
  167.  
  168.  
  169. NOTE:
  170.  
  171. 1.    The emulator requires the following paths to be specified:
  172.     
  173.     SNAP:        directory path for snapshots
  174.     DSK:        directory path for disk images
  175.     TAPE:        directory path for tape files
  176.     A-CPC:        directory path for A-CPC code and subdirectories.
  177.         
  178.     If you are installing A-CPC to a harddrive, and A-CPC is not
  179.     in the root, you will need to add the following lines
  180.     to your system-startup file. Alternatively, the A-CPC_Init file
  181.     can be modified to setup the paths, and you can double-click on
  182.     the icon to set them up.
  183.     
  184.     A-CPC_Init requires IconX to run.
  185.     
  186.     assign SNAP:    <path to snapshots>
  187.     assign DSK:    <path to disk images>
  188.     assign TAPE:    <path to tape files>
  189.     assign A-CPC:    <path to a-cpc files>
  190.     
  191.     e.g.
  192.     
  193.     assign A-CPC: DH0:Utils/emulators/A-CPC/
  194.  
  195. 2.    There are 6 versions of A-CPC in the registered version
  196.  
  197.     - A-CPC standard emulation for 68000 processor, (A-CPC_68000)
  198.     - A-CPC standard emulation for 68010 or greater, (A-CPC_68010)    
  199.     - A-CPC standard emulation for 68020 or greater, (A-CPC_68020)
  200.     - A-CPC plus emulation for 68000, (A-CPC_68000_plus)
  201.     - A-CPC plus emulation for 68010 or greater, (A-CPC_68010_plus)
  202.     - A-CPC plus emulation for 68020 or greater, (A-CPC_68020_plus)
  203.  
  204.     The registered version also contains two special versions
  205.     for 68020 or better processors. It takes advantage of some
  206.     of the extra commands available on these chips and the code
  207.     is slightly different to minimise delays from writing to memory.
  208.     
  209.     If your Amiga has a 68020/68030/68040/68060 choose this
  210.     version in preference. I believe there is about 5% speed increase
  211.     over the standard 68010 version.
  212.  
  213.     There are 3 version of A-CPC in the demo/evaluation version
  214.     
  215.     - A-CPC standard emulation for 68000 processor, (A-CPC_68000)
  216.     - A-CPC standard emulation for 68010 or greater, (A-CPC_68010)
  217.     - A-CPC standard emulation for 68020 or greater, (A-CPC_68020)
  218.     
  219. ----------------------------------------------------------------------------
  220.  
  221. Running the Emulator
  222. ====================
  223.  
  224. The emulator can be run from CLI or from Workbench. It requires a config
  225. file.
  226.  
  227. 5 Configuration files have been supplied which define the CPC type that
  228. will be emulated:
  229.  
  230. cpc464.config    - CPC 464 
  231. cpc664.config    - CPC 664
  232. cpc6128.config    - CPC 6128
  233. 464plus.config    - 464+    (registered version only)
  234. 6128plus.config - 6128+ (registered version only)
  235.  
  236. At the CLI type:
  237.  
  238. A-CPC_68000 <config_filename>
  239.  
  240. e.g.
  241.  
  242. A-CPC_68000 cpc464.config
  243.  
  244. Or from Workbench you can double click on the config icons themselves
  245. and the emulator will automatically be loaded. The config files have
  246. been set to load the 68020 version of the emulator. If you wish to change
  247. this select the icon, choose "Information" from the menu and change the
  248. Tool to "A-CPC_68000".
  249.  
  250. Or, you can double click on the A-CPC icon and enter a config file after
  251. the A-CPC filename.
  252.  
  253. ----------------------------------------------------------------------------
  254. Some games crash... why?
  255. ========================
  256.  
  257. The emulator cannot run 100% of games. Many programmers have used
  258. special features of the z80 which are not documented officially. I have
  259. had to try and find all these features, so that I can produce an accurate
  260. emulation.
  261.  
  262. So, if a game uses some of these instructions, and I have not emulated
  263. them correctly, then they will not work properly. Also, not all instructions
  264. have been emulated correctly, and there are still some hard to find bugs.
  265.  
  266. Some games will work, but you need to change the interrupt count value.
  267. These games rely on the time between interrupts, and if the time is too
  268. short, they start to corrupt themselves. To solve this change the interrupt
  269. count to a larger value and try the game again.
  270.  
  271. One game which has this problem is Elite. On 68000 change INT_SPEED to 1000
  272. and try running it again.
  273.  
  274. -----------------------------------------------------------------------------
  275.  
  276.  
  277. Running Games
  278. =============
  279.  
  280. Snapshots:
  281.  
  282. Snapshots are simply a dump of the memory with the information about
  283. the state of the hardware which are used to restart a program at the
  284. point the snapshot was saved.
  285.  
  286. The file format is the same as used by CPCEMU and CPE and they
  287. have the ".SNA" extension. 
  288.  
  289. Almost all snapshots should work, except for Alien Highway.
  290.  
  291. Disk images:
  292.  
  293. Disk images are a file containing a copy of the data on a disk. They
  294. can be created using CPCTRANS.EXE with CPCEMU on the PC, or with Make_DSK
  295. which is provided in the registered version of this emulator.
  296.  
  297. The file format is the same as used by CPCEMU and CPE. As in CPCEMU you
  298. can write to disk images (registered version only!). Disk images have
  299. the ".DSK" extension.
  300.  
  301. To use a disk image you need to "Insert the disk into drive X". Select
  302. the option from the Files menu and choose the disk image file.
  303.  
  304. Tape files:
  305.  
  306. These are files on an Amiga disk. Binary and Basic files must have
  307. an Amsdos header to be recognised. To use Tape files you must select
  308. tape operation (|TAPE), then you can run the files.
  309.  
  310.  
  311. Loading from Disk Images or Tape files:
  312.  
  313. With Disk or Tape files you will need to use Amsdos commands and Basic
  314. commands. 
  315.  
  316. If you have not used an Amstrad before the following commands should
  317. help you to run software.
  318.  
  319. (The "|" symbol is obtained by pressing SHIFT and @ key on the CPC keyboard)
  320.  
  321. |TAPE
  322.     Choose to load from tape
  323.  
  324. |DISC
  325.     Choose to load from disc    
  326.  
  327. |CPM    
  328.     Boot CPM from a CPM disk or this will run some games that
  329.     do not have files in the directory.
  330.  
  331.  
  332. CAT or |DIR
  333.  
  334.     This will display a list of files on the disc or tape.
  335.  
  336. RUN"<filename>.<ext>
  337.  
  338.     This will RUN a file on the disc or tape. If the file
  339.     doesnt have a ".  ", ".BAS" or ".BIN" extension then you
  340.     will have to specify it.
  341.     
  342.     e.g.    RUN"NEBULUS
  343.     
  344. LOAD"<filename>.<ext>
  345.  
  346.     Load a file into memory. It will not run it. Basic files
  347.     can be shown by typing "LIST".
  348.     
  349. |ERA,"<filename>.<ext>
  350.  
  351.     Delete a file on the disc
  352.     
  353. |REN,"<newfilename>.<newext>","<oldfilename>.<oldext>"
  354.  
  355.     Rename a file on the disc.
  356.  
  357. |A
  358.  
  359.     Choose drive A
  360.     
  361. |B
  362.     Choose drive B
  363.     
  364. ----------------------------------------------------------------------------
  365.  
  366. Keyboard
  367. ========
  368.  
  369. The following Amiga keys are used as a short cut:
  370.  
  371. F1    - Load Snapshot
  372. F2    - Save Snapshot
  373.  
  374. F8    - Multiface Stop Button (registered version only)
  375. F9    - Reset CPC
  376. F10    - Quit emulator
  377.  
  378. The Amiga keyboard has a different layout than the CPC, and the keys
  379. are not marked the same, so you may find a problem trying to find
  380. the CPC key. Here is a list of CPC keys and their Amiga equivalents:
  381.  
  382. CPC    Amiga
  383.  
  384. !1    !1
  385. "2    "2
  386. #3    #3
  387. $4    $4
  388. %5    %5
  389. &6    ^6
  390. '7    &7
  391. (8    *8
  392. )9    (9
  393. _0    )0
  394. -=    _-
  395. ^ pound    +=
  396. CLR    |\ or DEL
  397.  
  398.  
  399. f0    keypad 0
  400. f1    keypad 1
  401. f2    keypad 2
  402. f3    keypad 3
  403. f4    keypad 4
  404. f5    keypad 5
  405. f6    keypad 6
  406. f7    keypad 7
  407. f8    keypad 8
  408. f9    keypad 9
  409. f.    keypad .
  410. small    keypad enter
  411. enter
  412. Q-P    Q-P
  413. A-L    A-L
  414. Z-M    Z-M
  415. @|    {[
  416. [{    ]{
  417. :*    :;
  418. +;    "'
  419. ]}    <RET> (key cut out of RETURN on International keyboards)
  420. \'    <SHIFT> (key cut out of SHIFT on International keyboards)
  421. <,    <,
  422. >.    >.
  423. ?/    ?/
  424. SPACE    SPACE
  425. DELETE    BACKSPACE
  426. TAB    TAB
  427. RETURN    RETURN
  428. ESC    ESC
  429. CLR    DEL
  430. SHIFT    LEFT OR RIGHT SHIFT
  431. CTRL    CONTROL
  432. COPY    LEFT ALT
  433.  
  434. ----------------------------------------------------------------------------
  435.  
  436. Configuration file
  437. ==================
  438.  
  439. The emulator needs a configuration file to run. The configuration filename
  440. and path is specified in the commandline:
  441.  
  442. e.g.
  443.  
  444. a-cpc_680x0 <device:path/filename of config file>
  445.  
  446. The configuration is used to define the CPC model and characteristics
  447. that A-CPC will emulate.
  448.  
  449. The minimum configuration file MUST contain the following:
  450.  - the location of a Operating System ROM (OS_ROM=)
  451.  - the location of a BASIC ROM (ROM=0 PATH=)
  452.  - size of the CPC RAM (RAM_K=)
  453.  
  454. The lines of the configuration may be in any order, and a line of
  455. configuration can be added by loading the configuration file into
  456. a text editor. 
  457.  
  458. The configuration will initialise the emulator to your prefered setup
  459. when it starts. Some of these options can be changed from within the
  460. emulator.
  461.  
  462. The following config command-lines are supported:
  463.  
  464. OS_ROM = <device:path/filename> [NOPATCH]
  465.  
  466.         This line defines the location of the file containing
  467.         the operating system data. The file must NOT have a
  468.         AMSDOS header.
  469.         
  470.         The keyword NOPATCH is optional. When a rom has been
  471.         found, the emulator will attempt to find a file
  472.         of the same name but with a ".patch" extension. 
  473.         
  474.         The patch file can be used to remove code to speed
  475.         up the emulation in places.
  476.         
  477.         If the keyword NOPATCH is present, the patch file
  478.         will not be loaded.
  479.     
  480.         This line must be present for the emulator to work.
  481.     
  482.         e.g.
  483.         
  484.         OS_ROM=A-CPC:roms/cpc6128-os.rom
  485.         
  486. ROM = <rom number> PATH=<device:path/filename> [NOPATCH]
  487.  
  488.         This line defines the rom number and the location
  489.         of the file containing the data. The file must NOT
  490.         have a AMSDOS header.
  491.         
  492.         This function allows the user to add extra roms in
  493.         addition to BASIC and AMSDOS in a rom position of
  494.         their choice. (rom position is in the range 0..15
  495.         for 6128 emulation, and 0..7 for 464 emulation so
  496.         that the operating system will notice it's existance)
  497.         
  498.         ROM 0 must be present for the emulator to work.
  499.  
  500.         The demo/evaluation version will only support BASIC
  501.         and AMSDOS ROMs.
  502.         
  503.         e.g.
  504.         
  505.         ROM = 1 PATH=A-CPC:roms/protext.rom NOPATCH
  506.         
  507. DRIVE_A = <device:path/filename>
  508.  
  509.         This line defines a disk image (DSK) that will be
  510.         automatically "inserted" into CPC drive A,
  511.         when the emulator is started.
  512.  
  513.         This function is not available on the demo/evaluation
  514.         version of the emulator.
  515.         
  516.         e.g.
  517.         
  518.         DRIVE_A=DSK:stormlord.dsk        
  519.  
  520. DRIVE_B = <device:path/filename>
  521.  
  522.         Same function as DRIVE_A, except the disk image will
  523.         be "inserted" into CPC drive B.
  524.         
  525. RAM_K = <size of CPC memory in decimal>
  526.  
  527.         This function defines the size of CPC memory. This value
  528.         must be divisible by 64. It's value must be in the range
  529.         64-576.
  530.         
  531.         This line must be present for the emulator to work.
  532.         
  533. PPI_PORT_B = <decimal value>
  534.     
  535.         PORT B of the 8255 PPI has the following bits:
  536.         
  537.         7     Tape read data
  538.         6    Centronics Busy
  539.         5    Expansion port device present
  540.         4    Screen refresh (50Hz/60Hz)
  541.         3..1    Machine name (Amstrad, Schneider etc)
  542.         0    Frame Flyback pulse
  543.         
  544.         You can specify this byte and change the name of the
  545.         computer. The CPC was created by Amstrad, but sold
  546.         by different companies in Europe. With this byte you
  547.         can have their name instead.
  548.         
  549. INT_SPEED = <decimal value>
  550.  
  551.         This function defines the number of opcodes that is
  552.         counted before a z80 interrupt is triggered.
  553.         
  554.         If this value is reduced, then interrupts will be faster,
  555.         if it is increased, then interrupts are slower.
  556.         
  557.         On faster Amigas, this value will need to be high (about
  558.         1500). 
  559.         
  560.         You may find that some games will not work. The reason
  561.         may be that the interrupts are too fast for the game.
  562.         Try changing this value, and you will find the game
  563.         will work.
  564.     
  565.         The default value is 800.
  566.         
  567. MULTIFACE_ROM = <device:path/filename>
  568.  
  569.         To use the Multiface II emulation you need a file containing
  570.         the ROM data. This line specifies the location of the file,
  571.         and if the file is found, the emulation is enabled. The ROM
  572.         must NOT have a AMSDOS header.
  573.         
  574.         See the section on the Multiface emulation for more information.
  575.  
  576.         This function is not present on the demo/evaluation version
  577.         of the emulator.
  578.         
  579.         e.g.
  580.         
  581.         MULTIFACE_ROM = A-CPC:roms/multiface.rom
  582.         
  583. SOUND = <decimal value>
  584.  
  585.         This function will enable (0) or disable (<>0) the sound 
  586.         before the emulator has been started. On slow Amigas music
  587.         and sound effects are not easy to recognise, so this
  588.         option is provided to turn off sound. Many times I have
  589.         found it annoying to listen to the sound.
  590.                 
  591.         You can turn the sound off or on from a menu
  592.         in the emulator.
  593.         
  594.         e.g.
  595.         
  596.         SOUND = 0
  597.         
  598. ----------------------------------------------------------------------------
  599.  
  600. ROM Patch file
  601. ==============
  602.  
  603. When the ROM data is loaded during configuration, A-CPC will attempt
  604. to load a patch file (this will not happen if the NOPATCH keyword 
  605. is present). The patch file is used to modify the ROM data to improve
  606. compatibility with A-CPC or to speed up it's operation in A-CPC.
  607.  
  608. It has been provided so that the main code of the emulator does not
  609. need to be changed specifically.
  610.  
  611. The patch file contains any number of entries. The entries have the
  612. form:
  613.  
  614. 1 word        offset in ROM data in bytes
  615. 1 word        low byte contains byte to poke at offset, high byte
  616.         is ignored.
  617.         
  618. NOTE:
  619.  
  620. If you wish to use ROMDOS with A-CPC, then you can use the same patch
  621. file as used with CPC AMSDOS.
  622.  
  623. ----------------------------------------------------------------------------
  624.  
  625. Multiface 2 Emulation (registered version only)
  626. =====================
  627.  
  628. A-CPC has built in support for Multiface 2 emulation. To use this feature
  629. you will need a copy of the Multiface 2 rom data. (A program has been provided
  630. for you to run on your CPC which will do this).
  631.  
  632. The Multiface 2 ROM is (c) copyright Romantic Robot Ltd, UK, and so I cannot
  633. include it.
  634.  
  635. The emulation will work just like the real thing. Programs can be frozen
  636. at any time and you can enter pokes or look at the memory. You can even
  637. save the memory out to a disk image (similar to a snapshot), and re-load
  638. it later to start from the same position.
  639.  
  640. If you have a utility for the Multiface such as Tearaway or Insider, this
  641. will work too. You will need a disk image of the utility.
  642.  
  643. In the emulator, you activate the multiface by pressing F8 or by selecting
  644. "Multiface Stop" from the menu, you should then see the familiar Multiface
  645. menu.
  646.  
  647. You will need to do the following to use this feature:
  648.  
  649. 1) Transfer the two files MULTSAVE.BAS and MULTSAVE.BIN to a CPC disk,
  650. 2) With the CPC turned off, connect the Multiface 2 to the expansion port,
  651. 3) Switch on the CPC, and insert the disc with the files on it and 
  652.    type:
  653.    
  654.    RUN"MULTSAVE
  655.  
  656. 4) The program will save the Multiface rom data to a file called
  657.    MULTFACE.BIN
  658.    
  659. 5) Transfer MULTFACE.BIN from the CPC disk to an Amiga disk, and 
  660.    copy it into the roms/ directory of A-CPC.
  661.  
  662. 6) Load a text editor and add the following line to any of the
  663.    config files:
  664.    
  665.    MULTFACE_ROM=A-CPC:roms/multface.rom
  666.    
  667. 7) Now run A-CPC..
  668.  
  669. NOTE:
  670.  
  671. I have successfully run this feature using the rom data from my own
  672. Multiface. This feature may or may not work with older versions of the
  673. Multiface. 
  674.  
  675. The Multiface for the CPC will not work with the Plus emulation
  676. because of differences in the disk roms. The multiface assumes the location
  677. of routines in the disk rom, and will crash if run with the wrong CPC.
  678. (If you own a Plus machine with a Plus compatible Multiface, I would
  679. be very interested to hear from you so that I can add support for Plus
  680. Multiface).
  681.  
  682. The CPC version of the Multiface will only work with the 464/664 and 6128.
  683. The Plus version of the Multiface will only work with the 464+ and 6128+.
  684.  
  685. Some protections will prevent programs from working if the Multiface is
  686. enabled. To reduce the chance of this happening, the Multiface is made
  687. invisible when the emulator is reset.
  688.  
  689. I have found that the Multiface emulation does not work with some games.
  690. I do not know what is causing this, this may occur on the original
  691. Multiface.
  692.  
  693. ---------------------------------------------------------------------------
  694.  
  695. A-CPC Utilities
  696. ===============
  697.  
  698. Format_DSK (registered version only)
  699. ==========
  700.  
  701. This utility will create a blank disk image in the format you specify
  702. so that you can save your own programs on it.
  703.  
  704. COMMAND FORMAT:
  705.  
  706. Make_DSK WRITE Dsk_filename FORMAT disk_format
  707.  
  708. dsk_filename
  709.     = Filename and path of DSK image to write
  710.     
  711. disk_format
  712.     = Name of the format
  713.  
  714. e.g.
  715.  
  716. Make_DSK write df1:programs.dsk format data
  717.  
  718. NOTE:
  719.  
  720. The following formats are supported:
  721.  
  722. DATA
  723. SYSTEM
  724. D1 (ROMDOS/RAMDOS)
  725. D10 (ROMDOS/RAMDOS)
  726.  
  727. ----------------------------------------------------------------------------
  728.  
  729. Make_DSK (registered version only)
  730. ========
  731.  
  732. Make_DSK will read any CPC format disk, even copy-protected discs, 
  733. and attempt to make a disk image. (The disk image is compatible with 
  734. CPCEMU). It has been designed so that you can use all your software with 
  735. A-CPC. 
  736.  
  737. If you have copy-protected software which you would like to use on
  738. A-CPC, then you must connect a 3" disc to your Amiga, or copy the disks to 
  739. 3.5". (Please contact me if you have been successful with connecting
  740. a 3" drive).
  741.  
  742. But, make sure that the copy you make does run on your CPC, otherwise
  743. it will not run on A-CPC either. However, this does not mean that the 
  744. software will work. The emulator doesnt emulate the CPC perfectly 
  745. there are still some hard to find bugs which may prevent the disk from 
  746. loading correctly. This probably applies to disks with heavy copy-protection.
  747.  
  748. Some protected software relies on error codes returned from the fdc.
  749. A-CPC supports some of these errors, but at this date, neither CPCEMU
  750. or CPE do, but I have been talking with the authors about it. So, if
  751. you create disk images from Make_DSK they may not work with CPCEMU or
  752. CPE.
  753.  
  754. Please Note: I do not authorise or condone the use of this program for
  755. backuping copy-protected software. You will need to obtain permission from
  756. the copyright holder before converting any disk.
  757.  
  758. COMMAND FORMAT:
  759.  
  760. Make_DSK 
  761.     Unit_Number Destination_FileName No_of_tracks No_of_sides Start_Side
  762.  
  763. Unit_Number 
  764.     = Amiga drive containing the CPC disk
  765.         e.g. 0, 1, 2 or 3
  766.             
  767. Destination_Filename 
  768.     = Filename and path of DSK image to write
  769.         e.g. ram:dsk_images/north_and_south-1.dsk
  770.  
  771. No_of_Tracks 
  772.     = Number of tracks to read from CPC disk
  773.         e.g. 40, 42 or 80
  774.     
  775.       NOTE: Some demos and games use track 40 and 41 to store more
  776.             data on a 40 track disk. If you are not sure of the
  777.             number of tracks used, enter 42.
  778.  
  779. No_of_Sides 
  780.     = Number of sides to read from CPC disk
  781.         e.g. 1 or 2
  782.         
  783. Start_Side 
  784.     = Side to start reading from. (e.g. if you have a side switch
  785.       on your CPC to use both sides of a 3.5" disc using AMSDOS,
  786.       you can choose the side to read with this parameter)
  787.         e.g. 0 or 1
  788.  
  789.  
  790. e.g.
  791.  
  792. Make_Dsk 0 df1:dsk_images/north_and_south-1.dsk 40 1 0
  793.  
  794.  
  795. NOTE:
  796.  
  797. For AMSDOS disks:
  798.  
  799. - 40 tracks (possibly 41 or 42 for copy-protected disks)
  800. - 1 side
  801.  
  802. For ROMDOS disks:
  803.  
  804. - 80 tracks
  805. - 2 sides
  806.  
  807. If you want to convert a CPC disk which needs a special program (on CPC
  808. disk or CPC ROM) to read the format, such as ROMDOS or any other DOS, then
  809. you will need a copy of this program to read the disk image and run
  810. it on A-CPC.
  811.  
  812. For ROMDOS use SAVEROMS to save a copy of the rom data, and add a 
  813. line to the config file.
  814.  
  815. I have successfully converted the following to disk image from my
  816. originals (these had some copy-protection):
  817.  
  818. North & South            Road Runner (US Gold version)
  819. Nightbreed            Target Renegade
  820. Run the Gauntlet
  821. Short Curcuit
  822. Barbarian
  823. Mr.Heli
  824.  
  825. ----------------------------------------------------------------------------
  826.  
  827. SAVEROMS.BAS (registered version only)
  828. ============
  829.  
  830. This is a program to run on your CPC. It will display a list of ROMs that
  831. are connected (e.g. PROTEXT,UTOPIA, ROMDOS etc). You can choose the name
  832. of the ROM and enter a filename, and it will save the rom data. 
  833.  
  834. To use this program, transfer it to an Amstrad disk and run it from AMSDOS.
  835.  
  836. You can use the ROM data  with A-CPC by modifying A-CPC config file.
  837.  
  838. When you transfer the files to the CPC, make sure there is not a AMSDOS
  839. header, otherwise the rom will not work.
  840.  
  841. ----------------------------------------------------------------------------
  842.  
  843. SAVEMULT.BAS (registered version only)
  844. ============
  845.  
  846. This is a program to run on your CPC. It is used to save a copy of the
  847. Multiface 2 rom data. 
  848.  
  849. To use this program:
  850.  
  851. 1) Copy the files onto a CPC disk,
  852. 2) Attach your Multiface to your CPC,
  853. 3) Switch on the CPC and run the program from AMSDOS
  854.  
  855. If everything works well, a file will be saved to the disc called
  856. MULTFACE.ROM.
  857.  
  858. See the section on the Multiface emulation for more information.
  859.  
  860. ----------------------------------------------------------------------------
  861.  
  862. SAVEBURN.BAS (registered version only)
  863. ============
  864.  
  865. This is a program to run on your CPC+. It is used to save the game
  866. Burning Rubber from the cartridge supplied with the Plus. Since the
  867. game is copyrighted, I cannot include a copy with this emulator, so
  868. I have provided this utility to save it, so you can play Burning Rubber
  869. on A-CPC.
  870.  
  871. To use the program:
  872.  
  873. 1) Copy the files to a CPC disk,
  874. 2) With the Burning Rubber/BASIC cartridge inserted run this program
  875. from BASIC,
  876.  
  877. 4 files will be written and they will be called:
  878.  
  879. BURNROM.1, BURNROM.2,BURNROM.3 and BURNROM.4.
  880.  
  881. 3) Copy these files to an Amiga disk and run the Make_Burning_Rubber
  882.    program. (This will create a Burning Rubber cartridge image suitable
  883.    to be used with the emulator).
  884.    
  885. 4) To play burning rubber select "Insert Cartridge" from the files menu
  886.    on the Plus version of A-CPC.
  887.  
  888. ----------------------------------------------------------------------------
  889.  
  890. Using CPC disks (registered version)
  891. ===============
  892.  
  893. If you want to use 3" or 3.5" disks that have CPC software on them without
  894. converting them into disk images then use this feature. Please note, that
  895. the speed of loading depends on the complexity of any copyprotection (if
  896. present) and the speed of your machine. On my vanilla A500 reading CPC
  897. disks under AMSDOS is slighly faster than reading disk images, purely
  898. due to the fact that I am only using 2 drives and the AmigaOS has to
  899. search through the disk image file and back again in these circumstances.
  900.  
  901. It will allow you to use all your CPC software, so you can then decided
  902. which games you want to convert to disk later to and store them on your
  903. harddrive.
  904.  
  905. As with the disk images, if a special program or rom is required to read
  906. a format on the CPC, this must be used in the emulator to read the format.
  907.  
  908. This feature will load some copyprotected software. Since much copyprotected
  909. software relies on undocumented commands or features and/or specific error
  910. codes from the Floppy Disk Controller, they may fail to load.
  911.  
  912. I been successful with the following disk formats:
  913.  
  914. - all standard AMSDOS (DATA,SYSTEM etc)
  915. - all standard ROMDOS (D1,D10 etc - using a ROM image)
  916. - some copyprotected disks including
  917.     Get Dexter
  918.     Jack Nicklaus' Golf
  919.     Target Renegade didnt run, probably because the copyprotection
  920.     was very complicated.
  921.     
  922. ----------------------------------------------------------------------------
  923.  
  924. Other emulators
  925. ===============
  926.  
  927. During the development of this emulator I have discovered that other
  928. CPC emulators exist:
  929.  
  930. PC:
  931.  
  932. CPCEMU v1.3b    by    Marco Vieth (ali@uni-paderborn.de)
  933.             (It can be found on Simtel mirrors)
  934.             
  935.             micros.hensa.ac.uk/pub/
  936.  
  937. CPE v5.0    by     Bernd Schmidt (crux@Pool.Informatik.Rwth-aachen.de)
  938.             ftp.nvg.unit.no/pub/cpc/incoming/cpe50.zip
  939.             ftp.nvg.unit.no/pub/cpc/incoming/cpe50src.zip
  940.  
  941. A CPC emulator by Herman Dullink, currently in beta. It doesnt use
  942. the same kind of emulation as in CPCEMU and CPE and it does support
  943. direct reading of CPC disks.
  944.  
  945. SIMCPC emulates a CPC (not very well) in black and white. It is not
  946. really meant as a serious emulation attempt, however it is a good laugh
  947. to look at.
  948.  
  949. There is also one other called CPCEMUII but I dont know anything else
  950. about it.
  951.  
  952. Amiga:
  953.  
  954. CPE        by    Bernd Schmidt (a very early version, Bernd doesnt
  955.             plan to update this emulator. It comes with source)
  956.             ftp.nvg.unit.no/pub/cpc/incoming/acpe_new.lzh
  957.  
  958. AMI-CPC        by    a french guy known in the scene as Hypnom.
  959.             He doesnt have internet access. It runs on 68020.
  960.  
  961. Unix:
  962.  
  963. (Unknown)    by    Mark Conmy (mpc@scs.leeds.ac.uk)
  964.             The emulator supports snapshots and disk images
  965.             to a useable degree. This has not been released
  966.             yet.
  967. Mac:
  968.  
  969. (unknown)    by    (unknown)
  970.             Aparently a CPC emulator for Mac is being developed.
  971.             I dont know any more than this. It is being
  972.             written by a guy on compuserve.
  973.             
  974. Archimedes:
  975.  
  976. !CPC        by    Mark Rison (rison@hep.cam.ac.uk).
  977.  
  978.             A good emulator, at the moment it only supports
  979.             Snapshots. He has had some difficulty with the
  980.             disk emulation.
  981.  
  982. (unknown)    by    "Face Hugger"
  983.             Aparently, a famous CPC demo coder has written
  984.             a CPC emulator for the Archimedes. This may
  985.             just be a rumour. I have not seen the emulator
  986.             so I dont know about it's status.
  987.  
  988. If you are writing an emulator please contact me.
  989.                                     
  990. --------------------------------------------------------------------------
  991.  
  992. Sources of CPC software and information
  993. =======================================
  994.  
  995. Firmware Guide by Bob Taylor and Thomas Defoe.
  996.     ftp.ibp.fr/pub/amstrad/misc/firmware.zip
  997.  
  998.     Now in electronic form.
  999.  
  1000. WWW:
  1001.     Unofficial Amstrad CPC WWW Resource
  1002.     http://www.cs.cf.ac.uk/User/K.E.W.Thacker/Amstrad/index.html
  1003.  
  1004.     and soon a mirror at http://www.nvg.unit.no
  1005.  
  1006.     It contains Amstrad related links and especially the CPC Guide
  1007.     which contains documentation on the CPC chips and more documents
  1008.     essential for emulator authors.
  1009.     
  1010. Newsgroups:
  1011.  
  1012. There is an Amstrad 8-bit specific newsgroup for talking about emulators
  1013. and all things Amstrad related.
  1014.  
  1015. comp.sys.amstrad.8bit
  1016.  
  1017. FAQ (Frequently Asked Questions):
  1018.  
  1019. There is a official FAQ for the Amstrad newsgroup. It is posted twice
  1020. a week, and it can also be found at:
  1021.  
  1022. ftp.ibp.fr/pub/amstrad/amstrad.faq
  1023.  
  1024. It is maintained by Emmanuel Roussin
  1025.  
  1026. Anonymous FTP:
  1027.  
  1028. At the prompt enter "anonymous" or "ftp", and your e-mail address for
  1029. the password.
  1030.  
  1031. ftp.ibp.fr    /pub/amstrad
  1032.  
  1033.         The files are mirrored from "Genesis the 8bit generation BBS"
  1034.         run by Emmanuel Roussin. (roussin@blaise.ibp.fr).
  1035.         
  1036.         This site contains a huge selection of public domain and shareware
  1037.         software for the CPC and much much more.
  1038.  
  1039.         This site is very busy during the day.
  1040.  
  1041.         There is no incoming directory. You must contact
  1042.         Emmanuel to sort out how to get the files to him.
  1043.         
  1044. ftp.nvg.unit.no    /pub/cpc/
  1045.         
  1046.         This site has lots and lots of games in snapshot
  1047.         and disk image format. It also has much more.
  1048.         Check out /pub/cpc/incoming for the latest uploads.
  1049.  
  1050.         This site can be busy during the day.
  1051.         
  1052.         You can put uploads into the /pub/cpc/incoming directory.
  1053.         
  1054. sunshine.informatik.uni-wuerzburg.de /pub/joscho/cpcemu
  1055.  
  1056.         mirror of the ftp.nvg.unit.no site. Limited ftp access.
  1057.         
  1058. ftp.demon.co.uk    /pub/cpm
  1059.  
  1060.         Software for CPC C/PM. Limited set of files.
  1061.         
  1062. BBS:
  1063.     Aspects (2:250/107) +44 1617920260 (UK)
  1064.     
  1065.     Genesis the 8bit Generation (2:320/220) +33 1 39 50 54 11 (France)
  1066.     
  1067.     Razormaid (2:2471/6009) +49 711 4204329 (Germany)
  1068.     
  1069.     ZNODE 51 +49 89 961 45 75 (Germany)
  1070.  
  1071. ==========================================================================
  1072.  
  1073. Please contact me if:
  1074. - you find a bug.
  1075.  
  1076.     Please supply this information:
  1077.     Amiga model, CPU, hardware connected, how the bug was generated.
  1078.     
  1079. - you find a game that does not work
  1080.  
  1081.     Some games will not work because they rely on undocumented
  1082.     features of the chips. But I might be able to improve the emulator
  1083.     if I can find bugs and fix them.
  1084.  
  1085. - you know about the "KC Kompact" computer made by a German firm
  1086. - e-mail addressess of CPC demo coders
  1087. - e-mail addressess of game companies who made games for the CPC
  1088. - information about other emulators
  1089. - connecting a 3" drive to the Amiga
  1090. - if the program supplied to save Plus cartridges works and if you
  1091.   have successfully had a cartridge image running on the plus emulation
  1092.   (this does not include the Burning Rubber cartridge)
  1093.   
  1094. All your comments are welcome. Especially ideas about increasing the
  1095. performance of the emulator.
  1096.  
  1097. ----------------------------------------------------------------------------
  1098.  
  1099. About the Author and the Program
  1100. ================================
  1101.  
  1102. I am a 20 year old male studying Computer Science at Cardiff University
  1103. in Wales in the United Kingdom. I am now in my 3rd year.
  1104.  
  1105. The whole of the emulator package was written on a vanilla A500 with
  1106. 2 disk drives and 1mb of Chip Ram, running Workbench 2.0.
  1107.  
  1108. It has taken me about a year and a half to write so far and it is my first 
  1109. ever program using the Amiga Operating System, and it is actually my
  1110. 2nd program I have written on the Amiga. (The first being an unfinished
  1111. Zool clone).
  1112.  
  1113. I am beginning to loose count of the number of times that a disk has
  1114. decided to become corrupted or the number of times the computer has
  1115. crashed, and I have had to reboot. Believe me that trying to develop
  1116. a program of this size on a A500 is a headache. The whole program
  1117. actually uses 3 disks. 1 disk for Devpac, 1 disk for Includes, 1 disk
  1118. for the source code and rom data. About another 30 disks hold snapshots
  1119. and disk images which I use to check the emulator is working correctly.
  1120. Thankfully, I am not used to a harddrive and the luxurys like large
  1121. amounts of memory after writing many programs on a CPC. (I wrote a Windows
  1122. system on the CPC and it took over half an hour to assemble!)
  1123.  
  1124. The source code takes about 15 mins to assemble. Not bad for about 700k
  1125. of source code.
  1126.  
  1127. The emulator should be 680x0 compatible. I have read through documentation
  1128. of other emulators and worked out what is needed for bare compatibility,
  1129. and when I can afford a new Amiga I will probably add 68020 enhancements
  1130. and more. Until then I will stick with the A500 and add as much as I can.
  1131. At least with the A500, when I change the code to speed things up, it is
  1132. noticeable.
  1133.  
  1134. I have only owned a A500 for two years now, previously I owned
  1135. a CPC6128. On the CPC I hacked lots of protections so I could transfer
  1136. tapes to disc, wrote a disk copier, a windows system, a windows-style
  1137. help system, picture converters, converted 100's of tunes from the Atari
  1138. ST, wrote some demos (many not complete), wrote a program to read PC
  1139. and Archimedes disks and with all this information I wrote the CPC Guide
  1140. which is available on the Unofficial Amstrad CPC WWW Resource. I can
  1141. still remember one Speedlock protection which had over 70 continuous
  1142. de-protection loops (all involving the dreaded R register!).
  1143.  
  1144. ----------------------------------------------------------------------------
  1145.  
  1146. Credits and Contributions
  1147. =========================
  1148.  
  1149. Many thanks to everyone who has contributed to the emulator and the WWW pages.
  1150. They are (in no specific order), sorry if I have missed you out:
  1151. Bernd Schmidt, Marco Vieth, Jim Boulton, Emmanuel Roussin, Herman Dullink,
  1152. Christian Emre Lysel and all the others.
  1153.  
  1154. ----------------------------------------------------------------------------
  1155.  
  1156. Contact:
  1157.  
  1158.  
  1159. Postal Address:
  1160.  
  1161.     Kevin Thacker,
  1162.     Fairhaven,
  1163.     Whiteway,
  1164.     Stroud,
  1165.     Gloucestershire,
  1166.     GL6 7EP
  1167.     England
  1168.     
  1169. E-Mail:
  1170.  
  1171.     K.E.W.Thacker@cs.cf.ac.uk (until June 96)
  1172.     
  1173. ----------------------------------------------------------------------------
  1174.  
  1175. Acknowledgements
  1176. ================
  1177.  
  1178. The ROMs included in this package (cpc464-os.rom, cpc464-basic.rom,
  1179. cpc664-os.rom, cpc664-basic.rom, cpc6128-os.rom, cpc6128-basic.rom,
  1180. cpc-amsdos.rom, plus-os.rom, plus-basic.rom and plus-amsdos.rom) are
  1181. (c) copyright Amstrad Plc and Locomotive Software. Permission has
  1182. been obtained to distribute them with the demo version and release
  1183. version of this emulator. Many thanks to Cliff Lawson and Richard Clayton.
  1184.  
  1185. The Multiface 2 is (c) copyright Romantic Robot Ltd.
  1186.  
  1187. Burning Rubber cartridge is copyright (c) Ocean Software, and Amstrad plc.    
  1188.  
  1189. ----------------------------------------------------------------------------